

**Amendments to the claims:**

1. (currently amended) In the operation of an embedded processor complex for controlling the programmability of a network processor, the processor complex including a plurality of protocol processor units (PPUs), each PPU containing at least one multiple core language processor (CLP) processors (CLPs), each CLP having at least two code threads, each PPU utilizing a plurality of coprocessors useful for executing specific tasks for the PPU, and multiple logical coprocessor interfaces to provide access between each CLP and the coprocessors, and two arbiters between the CLPs and the coprocessors.
2. (original) In the operation according to claim 1, wherein the coprocessors include dedicated coprocessors that support multiple code threads of each CLP.
3. (original) In the operation according to claim 1, wherein the coprocessors are selected from the group including a tree search coprocessor, a checksum coprocessor, a stringcopy coprocessor, an enqueue coprocessor, a datastore coprocessor, a CAB coprocessor, a counter coprocessor and a policy coprocessor.
4. (Currently amended) In the operation according to claim 3 further including wherein one of the arbiters is a coprocessor execution interface arbiter to determine the priority between multiple threads.

5. (Currently amended) In the operation according to claim 3 including wherein one of the arbiters is a coprocessor data interface arbiter that determines the priority between data threads.

6. (original) In the operation according to claim 3 further including a FIFO buffer between each CLP and at least one coprocessor.

7. (original) In the operation according to claim 6, wherein the FIFO buffer is between each CLP and the counter coprocessor.

8. (original) In the operation according to claim 6, wherein the FIFO buffer is between each CLP and the policy coprocessor.

9. (currently amended) A network processing system including an embedded processor complex for controlling the programmability of a network processor, said complex including a plurality of protocol processor units (PPUs), each PPU containing:

- a) at least one two core language processor (CLP) processors (CLPs), each CLP having at least two code threads;
- b) a plurality of coprocessors for executing specific tasks for the system, and
- c) multiple coprocessor interfaces to access and share the resources of the coprocessors with each CLP, and
- d) two arbiters between the CLPs and the coprocessors.

10. (original) The network processing system of claim 9 wherein the coprocessors are dedicated to supporting the code threads of each CLP.
11. (original) The network processing system of claim 10 wherein the coprocessors are selected from the group including a tree search coprocessor, checksum coprocessor, stringcopy coprocessor, enqueue coprocessor, datastore coprocessor, CAB coprocessor, counter coprocessor and policy coprocessor.
12. (original) The network processing system of claim 10 further including a FIFO buffer between each CLP and at least one of the coprocessors.
13. (original) The network processing system of claim 12 wherein the FIFO buffer is between each CLP and the counter coprocessor.
14. (original) The network processing system according to claim 12 wherein the FIFO buffer is between each CLP and the policy coprocessor.
15. (original) The network processing system of claim 9 including specific operating instructions executed by the threads of the CLPs which result in commands to control coprocessor operation, which commands flow through the interface between the CLPs and the coprocessors.

16. (original) The network processing system according to claim 15 wherein the instructions serve to enable conditional execution of specific coprocessor operations.

17. (original) The network processing system according to claim 15 wherein the instructions enable the system to identify long latency events and short latency events according to the expected response time to access data in response to a particular coprocessor command, and to grant full control to another thread when execution of an active thread stalls due to a long latency event, or to grant temporary control to another thread when execution of an active thread stalls due to a short latency event.

18. (currently amended) A method of controlling the execution of instructions within an embedded processor complex which contains a plurality of protocol processor units (PPUs), each protocol processor unit containing at least one two core language processor (CLP) processors (CLPs), each CLP having at least two code threads, comprising the use by each PPU of a plurality of coprocessors for executing specific tasks for the PPUs, and the use of multiple logical coprocessor interfaces to provide access between the coprocessors and each CLP, and two arbiters between the CLPs and the coprocessors.

19. (original) The method according to claim 18 including the use of dedicated coprocessors that support the multiple code threads of the PPU.

20. (original) The method according to claim 19 wherein one or more of the coprocessors are selected from the group including a tree search coprocessor, checksum coprocessor, stringcopy coprocessor, enqueue coprocessor, datastore coprocessor, CAB coprocessor, counter coprocessor and policy coprocessor.

21. (original) The method according to claim 20 wherein a coprocessor execution interface arbiter serves to determine the priority between execution threads.

22. (original) The method according to claim 20 wherein a coprocessor data interface arbiter serves to determine the priority between data threads.

23. (original) The method according to claim 20 further including providing a FIFO buffer between each CLP and at least one of the coprocessors.

24. (original) The method according to claim 23 wherein the FIFO buffer is between each CLP and the counter coprocessor

25. (original) The method according to claim 23 wherein the FIFO buffer interface is between each CLP and the policy coprocessor.

26. (Currently amended) The method of claim 18 21 including the step of providing specific operating instructions executed by the CLPs which result in

commands to control coprocessor operation, which commands flow through the interface between the CLPs and the coprocessors.

27. (original) The method according to claim 26 wherein the operating instructions enable conditional execution of specific coprocessor operation.

28. (original) The method according to claim 27 wherein the execution is either direct or indirect.

29. (original) The method according to claim 18 including the step of providing instructions that enable the system to identify long latency events and short latency events according to the expected response time to a particular coprocessor command, and to grant full control to another thread when execution of an active thread stalls due to a long latency event, or to grant temporary control to another thread when execution of an active thread stalls due to a short latency event.

30. (new) The networking processing system according to claim 9 wherein each core language processor contains an arithmetic logic unit.

31. (new) The network processing system according to claim 9 wherein each coprocessor contains special purpose registers and each of the core language processors contains copies of the special purpose registers contained in each coprocessor.